<template>
    <div id="discount-popup" class="ns-box shadow w-[85.71vw] md:w-[60vw] lg:w-[60vw] xl:w-[40vw] relative">
        <div class="flex-shrink-0 flex justify-between items-center p-2 border-b ns-box-header">
            <div>
                <h1 class="text-xl font-bold text-fontcolor text-center" v-if="type === 'product'">{{ __( 'Product Discount' ) }}</h1>
                <h1 class="text-xl font-bold text-fontcolor text-center" v-if="type === 'cart'">{{ __( 'Cart Discount' ) }}</h1>
            </div>
            <div>
                <ns-close-button @click="closePopup()"></ns-close-button>
            </div>
        </div>
        <div id="screen" class="h-16 ns-box-body text-white flex items-center justify-center">
            <h1 class="font-bold text-3xl">
                <span v-if="mode === 'flat'">{{ nsCurrency( finalValue ) }}</span>
                <span v-if="mode === 'percentage'">{{ finalValue }}%</span>
            </h1>
        </div>
        <div id="switch-mode" class="flex">
            <button v-if="! popup.params.reference.disable_flat" @click="setPercentageType('flat')" :class="mode === 'flat' ? 'bg-tab-active' : 'bg-tab-inactive text-secondary'" class="outline-hidden w-1/2 py-2 flex items-center justify-center">{{ __( 'Flat' ) }}</button>
            <hr v-if="! popup.params.reference.disable_flat" class="border-r border-box-edge">
            <button v-if="! popup.params.reference.disable_percentage" @click="setPercentageType('percentage')" :class="( mode === 'percentage' ? 'bg-tab-active' : 'bg-tab-inactive text-secondary' ) + ' ' + ( ! popup.params.reference.disable_flat ? 'w-1/2' : 'w-full' )" class="outline-hidden py-2 flex items-center justify-center">{{ __( 'Percentage' ) }}</button>
        </div>
        <ns-numpad :floating="true" @next="submitValue()" @changed="inputValue( $event )" :value="finalValue" limit="1000"></ns-numpad>
    </div>
</template>
<script lang="ts">
import { nsCurrency } from '~/filters/currency';
import { __ } from '~/libraries/lang';
import popupCloser from '~/libraries/popup-closer';
import popupResolver from '~/libraries/popup-resolver';

export default {
    name: 'ns-pos-discount-popup',
    props: [ 'popup' ],
    data() {
        return {
            finalValue: 1,
            virtualStock: null,
            popupSubscription: null,
            mode: '',
            type: '',
            allSelected: true,
            isLoading: false,
            keys: [
                ...([7,8,9].map( key => ({ identifier: key, value: key }))),
                ...([4,5,6].map( key => ({ identifier: key, value: key }))),
                ...([1,2,3].map( key => ({ identifier: key, value: key }))),
                ...[{ identifier: 'backspace', icon : 'la-backspace' },{ identifier: 0, value: 0 }, { identifier: 'next', icon: 'la-share' }],
            ]
        }
    },
    mounted() {
        this.mode           =   this.popup.params.reference.discount_type || 'percentage';
        this.type           =   this.popup.params.type;

        if ( this.mode === 'percentage' ) {
            this.finalValue     =   this.popup.params.reference.discount_percentage || 1;
        } else {
            this.finalValue     =   this.popup.params.reference.discount || 1;
        }

        this.popupCloser();
    },
    methods: {
        __,
        nsCurrency,
        popupResolver,
        popupCloser,

        submitValue() {
            this.popup.params.onSubmit({
                discount_type           :   this.mode,
                discount_percentage     :   this.mode === 'percentage' ? this.finalValue : undefined,
                discount                :   this.mode === 'flat' ? this.finalValue : undefined
            });

            this.popup.close();
        },
        
        setPercentageType( mode ) {
            this.mode       =   mode;
        },
        closePopup() {
            this.popup.close();
        },

        inputValue( key ) {
            this.finalValue = key;
        }
    }
}
</script>